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TREE-BASED INTERFACE APPARATUS FOR DISPLAY OF 
CALL DEPENDENCIES AND METHOD THEREFOR 

CROSS REFERENCE TO RELATED APPLICATION 

The present invention is related to U.S. Patent Application, Serial No. 

08/_ (Attorney Docket No. AT9-98-466), entitled Apparatus for 

Cross Referencing Routines and Method Therefor. 

TECHNICAL FIELD 

The present invention relates in general to data processing systems, and in 
particular, to the display of call dependencies in software programs. 

BACKGROUND INFORMATION 



It is commonplace in the data processing art for software to be written in a 
modular structure. The tasks which the software performs are typically embodied in a 
1 0 set of subtasks which, depending on the development environment, may be referred to 

as procedures, functions, methods, subroutines or events. An event is a particular 
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software routine that receives user interactions via standard user interface devices. 
Although, again depending on the development system, these may have different 
connotations, for the purposes of the present invention they will be collectively 
referred to as routines. 

A complex software program which may be typical of the complex tasks 
performed by modern data processing systems may include a multitude of such 
procedures. Moreover, routines typically refer to other routines, whereby a 
hierarchical structure results. In a sophisticated software product, a complex 
hierarchical, or nested, chain of routine references may result. Tracking this 
hierarchical chain of dependencies as a development of a software program 
progresses, may be difficult. Additionally, maintenance of the product, which may be 
performed by persons other than the developers, may also be complicated by the 
complex hierarchical structure. Thus, there is a need in the art for a mechanism to 
track and display the cross referencing of procedures in data processing software, 
thereby allowing the programmer to have knowledge of the calling and called routines 
that will be affected if changes are applied to any given routine. 
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SUMMARY OF THE INVENTION 



The aforementioned needs are addressed by the present invention. 
Accordingly, there is provided, in a first form, a method of displaying hierarchical 
5 call dependencies. The method includes the step of selecting a routine from a routine 

list displayed in one of the first and second window regions. Displaying one of a first 
routine called by the routine and a second routine calling the routine in response to 
the selection constitutes another step of the method. 

There is also provided, in a second form, a data processing system circuitry 
10 operable for selecting a routine from a routine list displayed in one of the first and 

second window regions. Also included is circuitry operable for displaying one of a 
first routine called by the routine and a second routine calling the routine in response 
to the selection. 

Additionally, there is provided, in a third form, a computer program product 
15 operable for storage on program storage media, the program product operable for 

displaying hierarchical call dependencies includes programming for selecting a 
routine from a routine list displayed in one of the first and second window regions, 
and programming for displaying one of a first routine called by the routine and a 
second routine calling the routine in response to the selection. 
20 The foregoing has outlined rather broadly the features and technical 

advantages of the present invention in order that the detailed description of the 
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invention that follows may be better understood. Additional features and advantages 
of the invention will be described hereinafter which form the subject of the claims of 
the invention. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

For a more complete understanding of the present invention, and the 
advantages thereof, reference is now made to the following descriptions taken in 
5 conjunction with the accompanying drawings, in which: 

FIGURE 1 illustrates, in block diagram form, a data processing in accordance 
with one embodiment of the present invention; 

FIGURE 2 illustrates, in flow chart form, a call dependency display 
methodology in accordance with an embodiment of the present invention; 
10 FIGURE 3 schematically illustrates a call table used in an embodiment of the 

present invention; and 

FIGURE 4 illustrates a display device in accordance with an embodiment of 
the present invention. 
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DETAILED DESCRIPTION 

The present invention provides a mechanism for the display of routine call 
dependencies in data processing software. A call dependency may refer either to a 
routine calling another routine, or to a routine being called by another routine. A 
5 database containing a plurality of data structures corresponding to the routines in the 

data processing software is accessed. A mechanism for the creation of the database is 
the subject matter of co-pending, commonly assigned U.S. Patent Application, 
entitled "Apparatus for Cross Referencing Routines and Method Therefor," hereby 
incorporated herein by reference. A display window is created which includes two 
1 0 routine lists. The first list is for the hierarchical display of routines that a selected 

routine calls. A second list is for the hierarchical display of routines called by a 
selected routine. Initially, the lists display all the routines in the software program. 
The user may then select routines in each of the lists for display, in hierarchical 
fashion, other routines which the selected routine calls, or which are called by the 
1 5 selected routine. The routine displayed depends on the list, either the first or the 

second, from which the selection is made and corresponds to a called or calling 
routine, respectively. 

In the following description, numerous specific details are set forth to provide 
a thorough understanding of the present invention. However, it will be obvious to 
20 those skilled in the art that the present invention may be practiced without such 



-6- 



AT9-98-346 



PATENT 



specific details. In other instances, well-known circuits have been shown in block 
diagram form in order not to obscure the present invention in unnecessary detail. 

Refer now to the figures wherein depicted elements are not necessarily shown 
to scale and wherein like or similar elements are designated by the same reference 
numeral through the several views. 

Referring first to FIGURE 1, an example is shown of a data processing 
system 100 which may be used for the invention. The system has a central processing 
unit (CPU) 110, which is coupled to various other components by system bus 1 12. 
Read only memory ("ROM") 1 16 is coupled to the system bus 1 12 and includes a 
basic input/output system ("BIOS") that controls certain basic functions of the data 
processing system 100. Random access memory ("RAM") 1 14, I/O adapter 1 18, and 
communications adapter 1 34 are also coupled to the system bus 1 1 2. I/O adapter 1 1 8 
may be a small computer system interface ("SCSI") adapter that communicates with a 
disk storage device 120. Communications adapter 134 interconnects bus 1 12 with an 
outside network enabling the data processing system to communicate with other such 
systems. Input/Output devices are also connected to system bus 1 12 via user interface 
adapter 122 and display adapter 136. Keyboard 124, track ball 132, mouse 126 and 
speaker 128 are all interconnected to bus 1 12 via user interface adapter 122. Display 
monitor 138 is connected to system bus 1 12 by display adapter 136. In this manner, a 
user is capable of inputting to the system throughout the keyboard 124, trackball 132 
or mouse 126 and receiving output from the system via speaker 128 and display 138. 
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Preferred implementations of the invention include implementations as a 
computer system programmed to execute the method or methods described herein, 
and as a computer program product. According to the computer system 
implementation, sets of instructions for executing the method or methods are resident 

5 in the random access memory 1 1 4 of one or more computer systems configured 

generally as described above. Until required by the computer system, the set of 
instructions may be stored as a computer program product in another computer 
memory, for example, in disk drive 120 (which may include a removable memory 
such as an optical disk or floppy disk for eventual use in the disk drive 120). Further, 

1 0 the computer program product can also be stored at another computer and transmitted 

when desired to the user's work station by a network or by an external network such 
as the Internet. One skilled in the art would appreciate that the physical storage of the 
sets of instructions physically changes the medium upon which it is stored so that the 
medium carries computer readable information. The change may be electrical, 

1 5 magnetic, chemical, biological, or some other physical change. While it is convenient 

to describe the invention in terms of instructions, symbols, characters, or the like, the 
reader should remember that all of these and similar terms should be associated with 
the appropriate physical elements. 

Note that the invention may describe terms such as comparing, validating, 

20 selecting, identifying, or other terms that could be associated with a human operator. 

However, for at least a number of the operations described herein which form part of 
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at least one of the embodiments, no action by a human operator is desirable. The 
operations described are, in large part, machine operations processing electrical 
signals to generate other electrical signals. 

Although the present invention and its advantages have been described in 
detail, it should be understood that various changes, substitutions and alterations can 
be made herein without departing from the spirit and scope of the invention as defined 

by the appended claims. 

Refer now to FIGURE 2 in which is illustrated display methodology 200 in 
accordance with the present invention. Methodology 200 is launched in step 201, and 
a window for the current transaction is displayed on a display device, such as, 
display 138 in FIGURE 1 . In response to user input, the software program for which 
the call dependencies are to be displayed is entered in step 204. In step 205, a routine 
type may be specified, which may be used to limit the initial called by and called lists 
to routines corresponding to that type. Exemplary types may include events and 
functions. 

In step 212, a routine database corresponding to the program selected in 
step 204 is opened. The routine database includes a plurality of data structures 
corresponding to the routines defined in the program. An apparatus and method for 
creating such a routine database, and the data structures therein, is the subject of 
co-pending, commonly assigned, U.S. Patent Application entitled, "Apparatus for 
Cross Referencing Routines and Method Therefor," incorporated herein by reference. 
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In step 214, a first entry in a call data structure, or call table, contained in the 
database opened in step 212, is accessed. An exemplary call table, which may be 
generated in accordance with the principals described in the above-referenced 
co-pending commonly assigned U.S. Patent Application, call table 300, is illustrated 
in FIGURE 3. 

Call table 300 includes a plurality of entries 302. Each entry includes a 
routine identifier (ID) field 304, and a routine-called ID field 306. There is at least 
one entry 302 for each routine in the software program whose called dependencies are 
to be displayed. The routine ID, or routine name, is contained in the corresponding 
routine ID field 304. If the routine whose identifier appears in field 304 calls another 
routine, the identifier corresponding to the routine called is contained in the 
corresponding routine-called ID field 306. Thus, because a given routine may call a 
plurality of other routines, there may be a plurality of entries 302 corresponding to a 
particular routine. 

Returning to FIGURE 2, in step 216, the routine identifier corresponding to 
the first entry is displayed in a routine list on a display device, such as, display 
device 138 in FIGURE 1. The routine list is displayed in a first window region and a 
second window region in the display window created in step 202. The first window 
region may be used to display, in hierarchical fashion, routines that a selected routine 
calls. Conversely, the second window region may display the routine list for showing 
routines which are called by a selected routine. The display window, and the first and 
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second window regions will be further described in conjunction with FIGURE 4. For 
simplicity, displaying a routine identifier may hereinafter be referred to as displaying 
a routine. It would be understood by an artisan of ordinary skill that for the purposes 
of the present invention, the display of the routine identifier is intended. Likewise, 
selecting a displayed routine identifier may simply be referred to as selecting a 
routine. 

In step 218, it is determined if the corresponding routine-called field contains 
an identifier corresponding to a called routine. If, an identifier is contained in the 
routine-called field (corresponding to the "No" branch in step 218) a first icon is 
associated with the routine displayed in step 216 in the routine list in the window 
region for the display of called routines. The first icon denotes that the associated 
routine has a call dependency that may be hierarchically displayed. This will be 
further described in conjunction with FIGURE 4. This window region may be 
referred to as the "calls" region. If, however, in step 218, the routine-called field is 
empty, the routine displayed in step 216 has no called dependencies and step 220 is 
bypassed. 

In step 222, each routine-called field 304 is searched for the identifier 
corresponding to the routine displayed in step 216. If the routine is found, in 
step 224, then that routine is itself called by another routine, and in step 226, the first 
icon, which indicates that the particular routine has an undisplayed called dependency 
is associated with the display of that routine in the window region corresponding to 
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the display of routines that call a particular routine. This window region may be 
referred to as a "called-by" region. If, however, in step 224, the identifier of the 
routine displayed in step 216 is not found, then, that routine is not called by another 
routine, and step 226 is bypassed. 

5 Steps 216-226 are repeated for each entry in the call table accessed in 

step 214. In step 228, it is determined if a last entry has been displayed. If not, in 
step 230, the next entry in the call table is accessed, and in step 232, it is determined 
if the routine corresponding to the identifier in the respective routine ID field 302 has 
been displayed. If it has not been displayed, then methodology 200 displays the 

1 0 routine by returning to step 216. Otherwise, the return is to step 2 1 8, and the call 

dependencies are then displayed by executing steps 218-226, as previously described. 

In step 234, it is determined if a user has selected a routine in the list displayed 
in the calls region box. If not, it is next determined, in step 236, if a routine in the list 
in the called-by window region has been selected. If not, methodology 200 returns to 

1 5 step 234, and loops between steps 234 and 236 until a selection is made. 

If, in step 234, the user selects a routine in the list displayed in the calls 
window region, in step 235, it is determined if a second icon is associated with the 
selected routine. The second icon, set in step 247 below, denotes that the call 
dependency of the selected routine is already displayed. If the second icon is 

20 displayed in step 235, the dependency is hidden in step 237, and methodology 200 

returns to step 234. 
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If, however, the call dependency is not already displayed in step 238, an 
entry 302 corresponding to the routine selected is accessed. In step 240, the 
corresponding routine-called ID field 306 is accessed. 

A given routine may call a plurality of routines within its definition. Thus, 
5 call table 300 may include a plurality of entries 302. In step 248, it is determined if a 

last entry has been accessed. If so, methodology 200 returns to step 234. Otherwise, 
a next entry is accessed, step 250, and methodology 200 returns to step 240 to obtain 
the identifier of the routine called and display it. 

For a selected routine, a hierarchy based on calling routines may also be 
1 0 displayed. If, in step 236, a selection in the called-by window region is made, it is 

determined in step 249 if the second icon is associated with the second routine. If so, 
the displayed call dependency is hidden in step 251, and methodology 200 returns to 
step 234. Otherwise, the routine called ID field 306 for a first call table entry 302 is 
accessed, step 252. 

15 In step 254, the corresponding routine ID field 304 is accessed. The calling 

routine is displayed in step 260, and the icon associated with the routine selected in 

step 236 is switched to the second icon, in step 261. 

A given routine may be called by a plurality of routines. Thus, call table 300 

may include a plurality of entries 302 containing the same routine in field 306. In 
20 step 262, it is determined if a last entry has been accessed. If so, methodology 200 

returns to step 234. Otherwise, a next entry is accessed, step 264 and 
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methodology 200 returns to step 254, to obtain the identifier of the calling routine and 
display it. If, in step 262 ? all entries 302 in the call table have been tested, then 
methodology 200 returns to step 234 and continues to loop through steps 234 and 236 
in order to process further selections. 

5 Referring now to FIGURE 4, there is illustrated therein an exemplary 

hierarchical display in accordance with the present invention. A window 402 is 
displayed on display device 138. Window 402 includes a called-by region 404 and a 
calls region 406. In each of regions 404 and 406, an exemplary list of routine 
identifiers, which will simply be referred to as routines, are displayed. Each routine 

1 0 in the list has an associated icon indicating whether the routine has any undisplay ed 

called dependencies. A first icon 408 denotes that the corresponding routine has an 
undisplayed call dependency. In the exemplary embodiment of FIGURE 4, the first 
icon 408 is a "+ n symbol If a call dependency of a routine in the list is displayed, a 
second icon is associated with the routine. In the exemplary embodiment of 

1 5 FIGURE 4, the second icon 41 0 is an "-" symbol. A routine with no call dependency 

has no associated icon. 

Call dependencies are displayed in a hierarchical fashion, forming a tree-based 
hierarchy, illustrated in called-by region FIGURE 4. The hierarchy displayed in 
called-by region 404 depicts the routine which calls the routine preceding it in the 

20 hierarchical tree. Thus, the routine n R_CascadeChangeApprovalMethod", shown 
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"highlighted" in region 404 is called by "Migrate", which, in turn, is called by 
"ImportEvent," etc. 

Likewise, routines which are called by a selected routine are displayed in calls 
region 406 in an hierarchical tree. Thus, for example, 

5 "R_CascadeChangeApprovalMethod" shown highlighted in region 406 calls, inter 

alia, "R_LoadActivitiesForChange" and "R_GetActivityIndexForChange. M The 
former itself calls other routines, which are displayed, as indicated by the "-" icon 
410, while the latter calls no other routines, and therefore has no associated icon. 

In an embodiment of the present invention, in both called-by region 404 and 

1 0 calls region 406, the call dependency hierarchy of a selected routine may be displayed 

by "mouse clicking" on the corresponding first icon 408, using mouse 126 in 
FIGURE 1 . Alternatively, the tree hierarchy may be displayed by positioning a 
cursor (not shown) at the selected routine, and activating Expand button 412. 
Additionally, a displayed hierarchy may be collapsed, or hidden, by mouse clicking 

1 5 on the second icon 4 1 0, or, alternatively, positioning a cursor at the selected routine 

and activating Reset button 414. 

Additionally, window 402 includes program region 416 and type region 418. 
The software program for which the call dependencies are to be displayed may be 
entered by a user in program region 416, for example, using keyboard 124 of 

20 FIGURE 1 . Similarly, the initial routine lists displayed may be restricted to a 
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particular type of routine by entering a type in region 418, as previously discussed in 
conjunction with FIGURE 2. 

The present invention provides a mechanism for displaying routine call 
dependencies in a software program in a tree hierarchy. Routines called by a selected 

5 routine are displayed in a hierarchical fashion. Similarly, a display, also in 

hierarchical fashion of routines calling a selected routine is also provided. The user 
may select a depth of the hierarchy of call dependencies for display, as well as 
limiting the display to a particular type of routine, such as, events. A call dependency 
hierarchy may be displayed or hidden, in response to user input. 

1 o Although the present invention and its advantages have been described in 

detail, it should be understood that various changes, substitutions and alterations can 
be made herein without departing from the spirit and scope of the invention as defined 
by the appended claims. 
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WHAT IS CLAIMED IS: 



1 1 . A method of displaying hierarchical call dependencies comprising the steps 

2 of: 

3 selecting a routine from a routine list displayed in one of a first and a second 

4 window region; and 

5 displaying one of a first routine called by said routine and a second routine 

6 calling said routine in response to said selection. 

1 2. The method of claim 1 wherein said first window region comprises a calls 

2 window region and said second window region comprises a called-by window region. 

1 3. The method of claim 1 wherein said routine list is contained in a plurality of 

2 data structures stored in a database. 

1 4. The method of claim 1 wherein said step of displaying one of said first routine 

2 and said second routine further comprises the step of displaying said one of said first 

3 and second routines in a tree hierarchy. 
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1 5. The method of claim 1 wherein said step of selecting said routine from a 

2 routine list comprises the step of selecting an icon associated with said routine, 

3 wherein said icon flags said routine as having an undisplayed routine dependency. 

1 6. The method of claim 1 further comprising the step of accessing a data 

2 structure stored in a database, said data structure having an entry corresponding to 

3 said routine, and wherein said step of displaying said one of said first and second 

4 routines comprises the step of displaying said one of said first and second routines in 

5 response to a routine identifier, corresponding to said one of said first and second 

6 routines, contained in a portion of said entry. 

1 7. The method of claim 6 wherein said step of displaying said one of said first 

2 and second routines further comprises the step of displaying said first routine in 

3 response to said routine identifier in a routine field of said entry. 

1 8. The method of claim 6 wherein said step of displaying said one of said first 

2 and second routines further comprises the step of displaying said second routine in 

3 response to said routine identifier in a routine called field of said entry. 

1 9. The method of claim 1 further comprising the step of specifying a routine 

2 type, and wherein said step of displaying said one of said first and second routines 
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3 comprises the step of displaying said one of said first and second routines in response 

4 to said routine type. 

1 10. The method of claim 1 further comprising the step of displaying said routine 

2 list in said first and second window regions. 
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1 11. A data processing system comprising: 

2 circuitry operable for selecting a routine from a routine list displayed in one of 

3 said first and second window regions; and 

4 circuitry operable for displaying one of a first routine called by said routine 

5 and a second routine calling said routine in response to said selection. 

1 12. The data processing system of claim 1 1 wherein said first window region 

2 comprises a calls window region and said second window region comprises a 

3 called-by window region. 

1 13. The data processing system of claim 1 1 wherein said routine list is contained 

2 in a plurality of data structures stored in a database. 

1 14. The data processing system of claim 1 1 wherein said circuitry operable for 

2 displaying one of said first routine and said second routine further comprises circuitry 

3 operable for displaying said one of said first and second routines in a tree hierarchy. 

1 15. The data processing system of claim 1 1 wherein said circuitry operable for 

2 selecting said routine from a routine list comprises circuitry operable for selecting an 



-20- 



AT9-98-346 



PATENT 



3 icon associated with said routine, wherein said icon flags said routine as having an 

4 undisplayed routine dependency. 

1 16. The data processing system of claim 1 1 further comprising circuitry operable 

2 for accessing a data structure stored in a database, said data structure having an entry 

3 corresponding to said routine, and wherein said circuitry operable for displaying said 

4 one of said first and second routines comprises circuitry operable for displaying said 

5 one of said first and second routines in response to a routine identifier, corresponding 

6 to said one of said first and second routines, contained in a portion of said entry. 

1 1 7. The data processing system of claim 1 6 wherein said circuitry operable for 

2 displaying said one of said first and second routines further comprises circuitry 

3 operable for displaying said first routine in response to said routine identifier in a 

4 routine field of said entry. 
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1 18. The data processing system of claim 16 wherein said circuitry operable for 

2 displaying said one of said first and second routines further comprises circuitry 

3 operable for displaying said second routine in response to said routine identifier in a 

4 routine called field of said entry. 



1 19. The data processing system of claim 1 1 further comprising circuitry operable 

2 for specifying a routine type, and wherein said step of displaying said one of said first 

3 and second routines comprises circuitry operable for displaying said one of said first 

4 and second routines in response to said routine type. 



1 20. The data processing system of claim 1 1 further comprising circuitry operable 

2 for displaying said routine list in said first and second window regions. 
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1 21. A computer program product operable for storage on program storage media, 

2 the program product operable for displaying hierarchical call dependencies, 

3 comprising: 

4 programming for selecting a routine from a routine list displayed in one of 

5 said first and second window regions; and 

6 programming for displaying one of a first routine called by said routine and a 

7 second routine calling said routine in response to said selection. 

1 22. The program product of claim 21 wherein said first window region comprises 

2 a calls window region and said second window region comprises a called-by window 

3 region. 

1 23 . The program product of claim 21 wherein said routine list is contained in a 

2 plurality of data structures stored in a database. 

1 24. The program product of claim 21 wherein said programming for displaying 

2 one of said first routine and said second routine further comprises programming for 

3 displaying said one of said first and second routines in a tree hierarchy. 

1 25. The program product of claim 21 wherein said programming for selecting said 

2 routine from a routine list comprises programming for selecting an icon associated 
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3 with said routine, wherein said icon flags said routine as having an undisplayed 

4 routine dependency. 

1 26. The program product of claim 2 1 further comprising programming for 

2 accessing a data structure stored in a database, said data structure having an entry 

3 corresponding to said routine, and wherein said programming for displaying said one 

4 of said first and second routines comprises programming for displaying said one of 

5 said first and second routines in response to a routine identifier, corresponding to said 

6 one of said first and second routines, contained in a portion of said entry. 

1 27. The program product of claim 26 wherein said programming for displaying 

2 said one of said first and second routines further comprises programming for 

3 displaying said first routine in response to said routine identifier in a routine field of 

4 said entry. 
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1 28. The program product of claim 26 wherein said programming for displaying 

2 said one of said first and second routines further comprises programming for 

3 displaying said second routine in response to said routine identifier in a routine called 

4 field of said entry. 

1 29. The program product of claim 21 further comprising programming for 

2 specifying a routine type, and wherein said step of displaying said one of said first 

3 and second routines comprises programming for displaying said one of said first and 

4 second routines in response to said routine type. 

1 30. The program product of claim 2 1 further comprising programming for 

2 displaying said routine list in said first and second window regions. 
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ABSTRACT OF THE DISCLOSURE 

Apparatus and methods for the hierarchical display of routine call 
dependencies in a software program are implemented. A list of routines in a 
5 preselected software program is displayed in first and second regions in a window on 

an display device. By selecting a routine in the list in the first region, one or more 
routines called by the selected routine are displayed, in a tree hierarchy beneath the 
selected routine. Selection of a routine in the list in the second region 
displays, in a tree hierarchy, routines that call the selected routine. 

10 
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DECLARATION AND POWER OF ATTORNEY FOR 
PATENT APPLICATION 

As a below named inventor, I hereby declare that: 

My residence, post office address and citizenship are as stated below next to my name; 

I believe I am the original, first and sole inventor (if only one name is listed below) or an 
original, first and joint inventor (if plural names are listed below) of the subject matter 
which is claimed and for which a patent is sought on the invention entitled 

TREE-BASED INTERFACE APPARATUS FOR DISPLAY OF 
CALL DEPENDENCIES AND METHOD THEREFOR 

the specification of which (check one) 

:is attached hereto, 

9was filed on 



as Application Serial No. 
and was amended on 



I hereby state that I have reviewed and understand the contents of the above identified 
specification, including the claims, as amended by any amendment referred to above. 

I acknowledge the duty to disclose information which is material to the patentability of 
this application in accordance with Title 37, Code of Federal Regulations, §1 .56. 

I hereby claim foreign priority benefits under Title 35, United States Code, §119 of any 
foreign application(s) for patent or inventor's certificate listed below and have also 
identified below any foreign application for patent or inventor's certificate having a filing 
date before thai of the application on which priority is claimed: 

Prior Foreign Application(s): Priority Claimed 

9 Yes 9 No 

(Number) (Country) (Day/Month/Y ear) 

I hereby claim the benefit under Title 35, United States Code, §120 of any United States 
application(s) listed below and, insofar as the subject matter of each of the claims of this 
application is not disclosed in the prior United States application in the manner provided 
by the first paragraph of Title 35, United States Code, §112, 1 acknowledge the duty to 
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disclose information material to the patentability of this application as defined in Title 
37, Code of Federal Regulations, §1.56 which occurred between the filing date of the 
prior application and the national or PCT international filing date of this application: 



(Application Serial #) (Filing Date) (Status) 



I hereby declare that all statements made herein of my own knowledge are true and that 
all statements made on information and belief are believed to be true; and further that 
these statements were made with the knowledge that willful false statements and the like 
so made are punishable by fine or imprisonment, or both, under Section 1001 of Title 1 8 
of the United States Code and that such willful false statements may jeopardize the 
validity of the application or any patent issued thereon. 

POWER OF ATTORNEY: As a named inventor, 1 hereby appoint the following 
attorneys and/or agents to prosecute this application and transact all business in the Patent 
and Trademark Office connected therewith. 

John W. Henderson, Jr., Reg. No. 26,907; James H. Barksdale, Jr., Reg. No. 24,091; 
Thomas E. Tyson, Reg. No. 28,543; Robert M. Carwell, Reg. No. 28,499; Jeffrey S. 
LaBaw, Reg. No. 31,633; Douglas H. Lefevc, Reg. No. 26,193; Casimer K. Salys, Reg. 
No. 28,900; David A. Mims, Jr., Reg. No. 32,708; Richard A. Henkler, Reg. No. 39,220; 
Anthony V. S. England, Reg. No. 35,129; Volel Emile, Reg. No. 39,969; Christopher A. 
Hughes, Reg. No. 26,914; Edward A. Pennington, Reg. No. 32,588; John E. Hoel, Reg. 
No. 26,279; Joseph C. Redmond, Jr., Reg. No. 18,753; Leslie A. Van Leeuwen, Reg. No. 
42,196; Marilyn S. Dawkins, Reg. No. 31,140; Kelly K. Kordzik, Reg. No. 36,571; Barry 
S. Newberger, Reg. No. 41,527; and Ross S. Garsson, Reg. No. 38,150. 

Send correspondence to: James J. Murphy, 5400 Renaissance Tower, 1201 Elm Street, 
Dallas, Texas 75270-2199, and direct all telephone calls to Kelly K. Kordzik at (512) 
370-2851. 



FULL NAME OF FIRST OR SOLE INVENTOR: ALAN CURTIS PERKINS 

INVENTOR'S SIGNATURE: ^Lt^ DATE: L^u^ 

RESIDENCE: 8750 Giuuyi o tDiite 

Indianapolis, Marion County, Indiana 46256 



Page 2 of 3 



JPN 13 1999 14=38 



PAGE . 05 



JAN-13-1999 15:35 CRM P. 06/11 



AT9-98-346 



CITIZENSHIP: U.S.A. 

POST OFFICE ADDRESS: (Same as Residence) 



FULL NAME OF SECOND EWENIQR: PAtfL BRIAN YOUNG 




INVENTOR'S SIGNATURE: \/^ » DATE: (Tcca*.^ P, I 

RESIDENCE: 8444 Harrington Road V V 

Indianapolis, Marion County, Indiana 46256 

CITIZENSHIP: U.S.A. 

POST OFFICE ADDRESS: (Same as Residence) 
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